package org.lql.algo.codecrush.week001;

/**
 * @author: liangqinglong
 * @date: 2025-07-23 16:53
 * @description: 125. 验证回文串 <a href="https://leetcode.cn/problems/valid-palindrome/description/">...</a>
 **/
public class IsPalindrome {

	/**
	 * 如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后，短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。
	 * <p>
	 * 字母和数字都属于字母数字字符。
	 * <p>
	 * 给你一个字符串 s，如果它是 回文串 ，返回 true ；否则，返回 false 。
	 * <p>
	 * 示例 1：
	 * <p>
	 * 输入: s = "A man, a plan, a canal: Panama"
	 * 输出：true
	 * 解释："amanaplanacanalpanama" 是回文串。
	 * 示例 2：
	 * <p>
	 * 输入：s = "race a car"
	 * 输出：false
	 * 解释："raceacar" 不是回文串。
	 * 示例 3：
	 * <p>
	 * 输入：s = " "
	 * 输出：true
	 * 解释：在移除非字母数字字符之后，s 是一个空字符串 "" 。
	 * 由于空字符串正着反着读都一样，所以是回文串。
	 */
	public boolean isPalindrome(String s) {
		int n = s.length();
		int left = 0;
		int right = n - 1;
		while (left < right) {
			while (left < right && !Character.isLetterOrDigit(s.charAt(left))) {
				left ++;
			}
			while (left < right && !Character.isLetterOrDigit(s.charAt(right))) {
				right--;
			}
			if (left < right) {
				if (Character.toLowerCase(s.charAt(left)) != Character.toLowerCase(s.charAt(right))) {
					return false;
				}
				left++;
				right--;
			}
		}
		return true;
	}

	public static void main(String[] args) {
		IsPalindrome isPalindrome = new IsPalindrome();
		System.out.println(isPalindrome.isPalindrome("A man, a plan, a canal: Panama"));
	}
}
